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(54) A method and apparatus for visualization of database search results 



(57) A method and apparatus for representing the re- 
sults of a search of a database. The present invention 
provides for creating a view of database search results 
via a tree structure in which detail is selected and context 
preserved. In the present invention, the tree structure 
(Fig.2a) is created (402) based on user specified param- 
eters. These parameters represent attributes of docu- 
ments stored in the database and may differ from the 
search parameters. The tree structure is then mapped 
(404) to a static reference surface which is visually per- 
ceived as three-dimensional. The reference surface is 
comprised of a detail area where detail of the tree struc- 
ture (Fig.2b) is displayed and a context area for display- 
ing other portions of the tree in less detail but which con- 
veys to the viewer a sense of context. The tree structure 
may be scrolled about the reference surface to bring por- 
tions of the structure into a direct detail view while retain- 
ing a context view of the overall tree. 
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Description 

The present invention relates generally to the field 
of information display, and in particular to providing a vis- 
ual display relating to the results of a database search. 

It is well understood that intormation visualizations 
provide insights to the underlying data. For example, for 
any given set of information, new information regarding 
patterns or relationships can be obtained by looking at 
attributes of the information. It is often useful to view the 
attributes of the information in a hierarchical structure. 
However, a difficulty lies in displaying large hierarchical 
structures in a limited display area. 

EP-A-435,601 discloses a technique for displaying 
and manipulating three-dimensional representations of 
a tree structure which have rotating substructures. 

US-A-4,752,889 describes a graphic display that 
shows links between chunks of knowledge. The user, 
with mouse clicks, can obtain a display of links from a 
displayed chunk of knowledge to other chunks of knowl- 
edge, which are added to the display. Screen scrolling 
mechanisms allow movement from one area of the over- 
all graph to another. 

EP-A-535,986 describes a method for centering a 
selected node of a node link structure along a centering 
line. The nodes are in rows, and each row extends 
across a centering line with links between nodes in ad- 
jacent rows. When a user requests a centering operation 
for an indicated node, a sequence of images is present- 
ed, each including a row that appears to be a continua- 
tion of the row with the indicated node and that includes 
a continued indicated node that appears to be a contin- 
uation of the indicated node. 

Furnas, G.W., "Generalized Fisheye Views," CHI "86 
Proceedings, ACM, April 1 986, pp. 1 6-23, describes fish- 
eye views that provide a balance of local detail and global 
context. Section 1 discusses fisheye lenses that show 
places nearby in great detail while showing the whole 
world, showing remote regions in successively less de- 
tail; a caricature is the poster of the "New Yorker's View 
of the United States." Section 3 describes a degree of 
interest (DOI) function that assigns to each point in a 
structure, a number telling how interested the user is in 
seeing that point, given the current task. A display can 
then be made by showing the most interesting points, as 
indicated by the DOI function. The fisheye view can 
achieve, for example, a logarithmically compressed dis- 
play of a tree, as illustrated by Fig. 4 of Furnas for a tree 
structured text file. Section 4 also describes fisheye 
views for botanical taxonomies, legal codes, text out- 
lines, a decisions tree, a telephone area code directory, 
a corporate directory, and UNIX file hierarchy listings. 
Section 5 indicates that a display-relevant notion of a pri- 
ori importance can be defined for lists, trees, acylic di- 
rected graphs, general graphs, and Euclidean spaces, 
unlike the geographical example which inspired the met- 
aphor of the "New Yorker's View," the underlying struc- 
tures need not be spatial, nor need the output be graphic. 



Fig. 6 of Furnas shows a fisheye calendar. 

EP-A-447,095 discloses a processor which 
presents a sequence of images of a workspace that is 
stretched to enable the usertoviewa part of a workspace 
5 in greater detail. The workspace includes a middle sec- 
tion and two peripheral sections that meet the middle 
section on opposite edges. Each of the sections appears 
to be a rectangular two-dimensional surface and they are 
perceptible in three dimensions. When the user is view- 

io ing the middle section as if it were parallel to the display 
screen surface, each peripheral section appears to ex- 
tend away from the user at an angle from the edge of the 
middle section so that the peripheral sections occupy rel- 
atively little of the screen. When the user requests 

'5 stretching, the middle section is stretched and the pe- 
ripheral sections are compressed to accommodate the 
stretching. When the user requests destretching, the 
middle section is destretched and the peripheral sections 
are decompressed accordingly. 

20 The present invention seeks to provide for the or- 
ganization and visualization of database search results 
independent of the search parameters. Often, it is desir- 
able to obtain properties of the search results independ- 
ent of the search parameters. For example, a search on 

25 a database may be performed by specifying the authors. 
It may be undesirable to limit the search by specifying a 
date. It may later be desirable to organize the search re- 
sults by date in order to determine when particular doc- 
uments were created. 

30 The present invention provides a method for gener- 
ating hierarchically related information for the results of 
a query to a database, said database for storing docu- 
ments, said method comprising the steps of: 

35 a) executing a search on a database to obtain a set 
of documents; 

b) receiving a set of N ordered user specified view 
preferences, each of said user specified view pref- 

40 erences defining a property of information stored in 
said database; 

c) generating an N + 1 level tree structure based on 
said set of documents and said set of N ordered user 

45 specified view preferences; 

d) displaying a reference surface on which said tree 
structure is displayed, said reference surface having 
a first area for showing a first portion of the tree struc- 

50 ture in detail and a second area for showing second 
portions of said tree structure lacking detail; 

e) determining a layout of said tree structure relative 
to said reference surface; 

55 

f) mapping said tree structure to said reference sur- 
face based on said layout to create tree display data; 
and 
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g) displaying said tree structure on said reference 
surface. 

The invention further provides a computer controlled 
display system according to claim 5 of the appended 
claims. 

In the present invention, a tree structure is created 
based on the search results and user specified parame- 
ters. The user specified parameters represent attributes 
of documents stored in the database and may differ from 
the search parameters. The tree structure is then 
mapped to a static reference surface which is visually 
perceived as three-dimensional. The reference surface 
is comprised of a detail area where detail of the tree 
structure is displayed and a context area for displaying 
other portions of the tree in less detail but which conveys 
to the viewer a sense of context. The tree structure may 
be scrolled about the reference surface to bring portions 
of the structure into a direct detail view while retaining a 
context view of the overall tree. 

Figure 1 is a block diagram of computer controlled 
display system in the currently preferred embodiment of 
the present invention. 

Figure 2a illustrates a tree structure laid out on a 
plane. 

Figure 2b illustrates the tree structure of Figure 2a 
which has been mapped to a reference surface of a pre- 
ferred embodiment of the present invention. 

Figure 3a illustrates a reference surface which is 
perceived as three-dimensional as is utilized in a pre- 
ferred embodiment of the present invention. 

Figure 3b is a side view of the reference surface of 
Figure 3a with respect to a user viewpoint. 

Figure 4 is a flowchart of the general steps per- 
formed when creating the visualization in a tree structure 
in a preferred embodiment of the present invention. 

Figure 5 is an example of a tree structure showing 
the results of a database search organized based on 
user specified preferences. 

Figure 6 is a flowchart of user interactions that may 
be performed in a preferred embodiment of the present 
invention. 

Figure 7 is a flowchart of the steps performed for 
generating the visualization of a tree structure in a pre- 
ferred embodiment of the present invention. 

Figure 8 is a flowchart of the steps for creation of the 
tree structure in a preferred embodiment of the present 
invention. 

Figure 9 is a flowchart of the steps for laying out a 
tree structure onto a plane in a preferred embodiment of 
the present invention. 

Figure 1 0 is a flowchart of the steps for scrolling the 
tree structure about the reference surface as may be per- 
formed in a preferred embodiment of the present inven- 
tion. 

Figure 1 1 illustrates a data structure for a node in a 
preferred embodiment of the present invention. 

Figure 1 2 a screen display of a tree view of the re- 



sults of a database search in a preferred embodiment of 
the present invention. 

Figure 1 3 is a screen display showing a highlighted 
path, in a preferred embodiment of the present invention. 
5 Figure 1 4 is a screen display showing a highlighted 
path after it has been scrolled into view, in a preferred 
embodiment of the present invention. 

A method and apparatus for visualization of the re- 
sults of a database search is described herein. In the fol- 
10 lowing description numerous specific details are set 
forth, such as data models for representing a tree struc- 
ture, in order to provide a thorough understanding of the 
present invention. It would be apparent, however, to one 
skilled in the art to practice the invention without such 
'5 specific details. In other instances, specific implementa- 
tion details such as the system calls for causing a tree 
structure to be displayed on a screen, have not been 
shown in detail in order not to unnecessarily obscure the 
present invention. 
20 Hierarchically related information is often represent- 
ed as a tree. As used herein, the term node will refer to 
a point on the tree structure. Each node includes pointers 
to a parent node, a child node and a sibling node to cre- 
ate the tree structure. A root node is the highest level 
25 node. Leaf nodes are the bottom level nodes. 

When a tree structure becomes large, it may be dif- 
ficult to present the entire tree on a display area in full 
detail. Thus, it may be difficult to trace that path of a node. 
Further, it is often desirable to know where a particular 
so node in a tree structure is located in order to understand 
the context of the data. The present invention addresses 
this by providing a three-dimensional context view of the 
tree which can be scrolled. 

It should be noted that a tree is in the general class 
35 of node-link structures. As will become apparent in the 
description below, the present invention could be imple- 
mented so as to support other node link structures. 

Various techniques are known in the art for render- 
ing three-dimensional images on two dimensional dis- 
40 play screens. However, manipulating three-dimensional 
images is computationaly intensive. Often, expensive 
3-D graphics hardware is used in order to render images 
in an acceptable timeframe. The present invention 
avoids the need for using sophisticated hardware to pro- 
p's vide a three dimensional visualization which can be ma- 
nipulated. In the present invention, a three dimensional 
reference surface is created, about which the information 
moves. This provides for seeing the entire composition 
or path to the end nodes of a tree structure. 
50 As will become apparent in the description below, a 
preferred embodiment of the present invention provides 
visualizations of the results of a database search (often, 
important information can be determined by examining 
relationships between the various search results.) How- 
ss ever, it would be apparent to one of skill in the art to apply 
the present invention to other hierarchically structured 
information. 
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Overview of a Computer Controlled Display System in 
the Currently Preferred Embodiment of the Present 
Invention 

Referring to Figure 1 , the computer based system 
on which the currently preferred embodiment of the 
present invention may be implemented is comprised of 
apluralityofcomponentscoupledviaabus 101. The bus 
101 may consist of a plurality of parallel buses (e.g. ad- 
dress, data and status buses) as well as a hierarchy of 
buses (e.g. a processor bus, a local bus and an I/O bus). 
In any event, the computer system is further comprised 
of a processor 102 for executing instructions provided 
via bus 101 from Internal memory 103 (note that the In- 
ternal memory 103 is typically a combination of Random 
Access and Read Only Memories). The processor 102 
will be used to perform various operations in support of 
creating the tree visualizations. Such operations that 
would be performed by the processor 102 are described 
with reference to Figures 6-10. The processor 102 and 
Internal memory 103 may be discrete components or a 
single integrated device such as an Application Specifi- 
cation Integrated Circuit (ASIC) chip. 

Also coupled to the bus 101 are a keyboard 104 for 
entering alphanumeric input, external storage 105 for 
storing data, a cursor control device 1 06 for manipulating 
a cursor, and a display 107 for displaying visual output. 
The keyboard 1 04 would typically be a standard QWER- 
TY keyboard but may also be telephone like keypad. The 
external storage 1 05 may be fixed or removable mag- 
netic or optical disk drive. The cursor control device 1 06, 
e.g. a mouse or trackball, will typically have a button or 
switch associated with it to which the performance of cer- 
tain functions can be programmed. 

The currently preferred embodiment of the present 
invention is designed for use on a commercially available 
I BM compatible computer system available from various 
vendors, and which is running the Microsoft Windows 3. 1 
Operating System. The Windows operating system pro- 
vides for the use of multiple workspaces concurrently. 
The operation of Windows-like operating systems is well 
known in the art. 

In operation, the currently preferred embodiment of 
the present invention will also make use of various user 
interface facilities. The cursor control device is used to 
position a cursor located on the display to a desired lo- 
cation (i.e. "point" to the desired location). When the cur- 
sor control device is positioned (i.e. pointing) to some- 
thing on a display, the button associated with the cursor 
control device may be depressed and released in order 
to invoke an action. This is referred to as a "click". A dif- 
ferent function may be invoked if the button is depressed 
and released twice in succession. This is referred to as 
a "double click." When a user points to an object on the 
display, depresses the button and holds it down, the ob- 
ject will follow the cursor and be placed at the location 
on the display where the button is released. This is re- 
ferred to as a "drag and drop" or "drag" operation. 



Overview of the Tree Visualization 

Figures 2a and 2b illustrate the visualization of a tree 
structure in the currently preferred embodiment. Figure 

5 2a illustrates a tree structure 201 which is projected onto 
a plane 202. Referring to Figure 2b, the same tree struc- 
ture 201" has been mapped onto a reference surface 
203. The reference surface 203 has a center panel 204 
sharing an edge with a top panel 205 and a bottom panel 

'0 206. The center panel 204 has a rectangular shape while 
the top panel 205 and bottom panel 206 have trapezoidal 
shapes. 

Although not illustrated, the reference surface may 
be rotated by 180 degrees. This may be done if it is de- 

15 sirable to have a vertical representation of a tree struc- 
ture. Further, the various levels of the tree structure of 
Figures 2a and 2b are aligned in columns. As will be- 
come apparent in the description below, such an align- 
ment reduces processing computations for scrolling of 

20 the tree structure across the reference surface and does 
not effect the underlying nature of the tree structure. 
However, it would be apparent to one of skill in the art to 
practice the present invention with a tree structure where 
the various levels are not vertically aligned in columns 

25 The reference surface provides visual cues so that 
the visualization is perceived as three dimensional. Fig- 
ures 3a and 3b illustrate the reference surface in greater 
detail. Figure 3a illustrates a reference surface as dis- 
played. The reference surface 300 is comprised of a 

30 center panel 301 , a top panel 302 and a bottom panel 
303. The top panel 302 is perceived as folded back from 
center panel 301 at fold edge 304. The bottom panel 303 
is perceived as folded back from center panel 301 at fold 
edge 305. In order to provide visual cues as to three-di- 

35 mensions (i.e.. it is folded back) the top panel 302 and 
bottom panel 303 have different fill patterns than center 
panel 301 . Further, the background of the reference sur- 
face may also be shaded to provide the three-dimension- 
al visual effect. 

40 Figure 3b is a side view of the reference surface 300 
with respect to user viewpoint 306. From Figure 3b, it is 
readily observed that the user viewpoint 306 is orthogo- 
nal to center panel 301 , whereas information on top pan- 
el 302 and bottom panel 303 are not. Accordingly, infor- 
ms mation in top panel 302 or bottom panel 303 are viewed 
in perspective. 

It should further be noted that the size of the display 
area for the reference surface may change. In the cur- 
rently preferred embodiment when the width of the dis- 
50 play area changes, all the panel widths correspondingly 
change. However, if there is a change to the height of 
the display area, only the center panel will change height. 
This is done to show the maximum number of nodes in 
detail while retaining context. And as will be described 
55 in greater detail below, it negates the need to update 
look-up tables used in creating the three-dimensional ef- 
fect of the tree structure. 

Figure 4 is a flowchart describing the general steps 
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performed for the rendering of the present invention's 
visualization of a tree structure. First, perspective trans- 
formation look-up tables for the top and bottom panels 
are created, step 401. These look-up tables are for cre- 
ating the display data for portions of the tree structure on 
the top and bottom panels. The look-up tables are static 
for the durations of the visualization. In a preferred em- 
bodiment, each look-up table stores 3000 sample points 
for transforming an orthogonal view to a perspective 
view. Values between the sample points are obtained 
through interpolation. Techniques for creating such a 
look-up table tocreate a perspective vieware well known 
in the art. Thus, further description on the generation of 
sample points in the look-up table is not deemed neces- 
sary. Next, the tree structure (i.e. the node/link pointer 
data) is created or otherwise obtained, step 402. Crea- 
tion of the tree structure is dependent on what the struc- 
ture represents. In a preferred embodiment, a hierarchi- 
cal view of the results of a database search are embod- 
ied in the tree structure. A description of the creation of 
the tree structure in a preferred embodiment is provided 
below. Once the tree structure is created or obtained, it 
is mapped to the reference surface by the following 
steps. First, the tree structure is laid out on a two dimen- 
sional plane, step 403. Initial layout of the tree structure 
will center the tree on the reference surface. Subsequent 
layouts, e.g. as an effect of scrolling, will cause the layout 
positions to move. In the laying out step, each node will 
obtain a planar address. The tree is then rendered onto 
the reference surface, step 404. This is accomplished by 
transforming the plane coordinates for the nodes to 
screen coordinates using the look-up tables generated 
in step 401 for nodes in the top and bottom panels and 
direct scaling for nodes in the center panel. 

When the visualization is presented to a user, the 
reference surface is displayed and the tree structure 
overlaid. The user invocation of and processing for 
scrolling of the tree structure is described in greater detail 
below. 

The rendering of the visualization is less computa- 
tionaly intensive because of the assumptions that the us- 
er's point of view is constant, i.e. orthogonal to the center 
panel and that the top and bottom panels are symmetric. 
However, it retains the benefit of a three-dimensional 
representation of viewing both context and detail concur- 
rently. 

The present invention is now described in reference 
to a preferred embodiment of viewing the results of a da- 
tabase search. However, it would be apparent to one of 
skilled in the art that the visualization of the present in- 
vention could be used for viewing any information capa- 
ble of representation in a tree structure. 

Information Visualization of Database Search Results 

In a preferred embodiment of the present invention, 
a database maintains a collection of documents. Each 
document has multiple indices by which it can be refer- 



enced. The present invention allows the results of a da- 
tabase search to be organized and viewed in a manner 
based on these indices. The indices used for organiza- 
tion and viewing may be different from the indices used 
5 for the database search. The indices which a user spec- 
ifies by which they would like to view the search results 
are termed preferences. 

The preferences that a user specifies are ordered. 
A first preference is used to create the top level of the 
10 tree structure, a second preference the second level, and 
so on until the bottom level of the structure which are 
representations of the individual items of the search re- 
sults (i.e. the documents.) Typically, the tree structure 
created from the search results will be shallow (the 
15 number of specified preferences plus 1) and broad (the 
number of documents in the search result.) A label on 
each node will indicate the corresponding value for the 
preference. Figure 5 illustrates an example of a view of 
a search result. In this view, a first preference is Authors, 
20 a second preference is Type and a third preference is 
Date. Referring to Figure 5, a top level 500 identifies 
three authors, Allen (node 501 ), Bowers (node 502) and 
Card (node 503). Following the Allen branch, in the sec- 
ond level of the hierarchy, Type, a grouping 504 of doc- 
25 ument types is specified, namely Spreadsheet (node 
504a), Report (node 504b) and Memo (node 504c). From 
the third level of the hierarchy, it is observed that the 
spreadsheet is dated 6/15/93 (node 505a), the report 
dated 12/1/93 (node 505b) and the Memo on 6/30/94 
30 (node 505c). Finally, we see that from the bottom level 
of the hierarchy the documents associated with the Allen 
branch (nodes 506-508). 

Following the Bowers branch, it is observed from the 
second level that documents authored by Bowers are of 
35 type Graphics (node 509a) or Code (node 509b). The 
documents of type Graphics were dated on 1/1/93 (node 
510a) and the code on 5/15/94 (node 510b). Finally, the 
documents associated with the Bowers chain are indi- 
cated in nodes 511-514. 
40 Following the Card branch, it is observed from the 
second level that documents authored by Card are of 
type Audio (node 51 5a) or Image (node 51 5b). From the 
third level, the documents of type Audio are dated 
3/24/94 (node 516a) and the documents of type Image 
45 are dated 2/16/94 (node 51 1 6b). Finally, the documents 
associated with the Card branch are defined by nodes 
517-519. 

In a preferred embodiment, each database that may 
be searched will have default preferences that may be 
so used for viewing a tree structure. 

It is also worth noting that the preferred embodiment 
operates within the parameters of a window system. For 
example, a display view may only show a portion of a 
tree structure because the window has been sized to be 
55 smaller than the actual size of the window display area. 
The preferred embodiment of the present invention 
is further described with reference to the flowchart of Fig- 
ure 6. Referring to Figure 6, a user first selects a data- 
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base and performs a database search, step 601 . Once 
the search is completed, the user may then specify how 
they would like to view the search results. In a preferred 
embodiment the user may view the results as a list of 
documents or in a tree structure. The user selects the s 
tree view, step 602. In the preferred embodiments, the 
various view options are represented as icons which the 
user selects by a point and click operation. Other means 
of view selection, e.g. via a pull-down menu could be 
used. Once the user selects the tree view, they must io 
specify the preferences upon which to build the tree 
structure, step 603. In a preferred embodiment, a user 
may select up to 5 preferences. The primary limitation 
being the size of a typical display. It would be apparent 
to one skilled in the art to allow a fewer or greater number is 
of preferences. 

The tree structure for the view is then created and 
displayed based on the search results and the prefer- 
ences, step 604. The manner in which the tree structure 
is built is described in greater detail below. At this point, 20 
the user may highlight a document path, view a docu- 
ment or cause a document to be retreived from the da- 
tabase. It should be noted that in a preferred embodi- 
ment of the present invention, each node is capable of 
being selected by a point operation using the cursor con- 25 
trol device. For any operation, the user first points to a 
desired node, step 605. Highlighting the document path 
through the tree structure is invoked by a single click of 
the cursor control device. The highlighting is accom- 
plished by displaying the path in reverse video (see Fig- 30 
ure 12). Before highlighting it must be determined if the 
document node corresponding to the pointed to node is 
in the center panel, step 606. If the document node is in 
the center panel, the document path is highlighted, step 
608. If the document node is not in the center panel, the 35 
tree view is rotated (i.e. scrolled) to bring the document 
node into the center of the center panel, step 607. This 
scrolling is done automatically. When completed, the 
document node will be centered in the center panel and 
the path highlighted per step 608. 40 

Viewing a document, step 609, is invoked by a dou- 
ble click of the cursor control device. The viewing mech- 
anisms of a preferred embodiment provide for retrieval 
of the corresponding document and for presentation on 
a window in the display. Retreiving a document for edit- 4S 
ing purposes, step 610 is accomplished through a drag 
and drop operation (into a predefined work area). Note 
that in a preferred embodiment, the node pointed to need 
not be the document node. It could be any node in the 
tree hierarchy which ultimately point to the desired doc- so 
ument. 

The creation and rendering of a tree structure in the 
currently preferred embodiment is described with refer- 
ence to the flowchart of Figure 7. Referring nowto Figure 
7, the underlying tree representation is created from the ss 
search results and the provided preferences, step 701. 
In a preferred embodiment, the tree consists of virtual 
nodes, the inner nodes which correspond to the prefer- 



ence values, and actual nodes, the leaf nodes (displayed 
in the right-most column) which correspond to the docu- 
ments resulting from the search. In a preferred embodi- 
ment, the creation of the tree is accomplished through 
recursive calls to a software program called AddNode. 
A flowchart outlining the functionality of AddNode is pro- 
vided in Figure 8. AddNode takes as input, a parent node 
and a document. In creating the tree AddNode is called 
for each document, specifying a root node as the parent 
node. Referring now to Figure 8, the value of the prefer- 
ence, say X, for the current depth in the hierarchy is ob- 
tained, step 801 . This would involve examining the da- 
tabase to determine the value of the index corresponding 
to the preference. A search is then made to determine if 
any child node has the value X, step 802. If no child node 
has the value X, then a new virtual child node having the 
value X is created, step 803. The depth of the hierarchy 
is then incremented, step 804. A check is then made to 
determine if the maximum depth in the hierarchy has 
been reached, step 805. If it has, then an actual node is 
created whose parent is the child with the value X (i.e. 
the current child), step 806. If a child having value X ex- 
ists, then AddNode is recursively called with that child as 
the new parent, step 807. 

Referring back to Figure 7, the tree structure is then 
laid out on a plane, step 702. It should first be noted that 
in a preferred embodiment each level in the hierarchy is 
in a column (which is not visible) of the display window. 
The steps for laying out the tree structure on a plane are 
illustrated in the flowchart of Figure 9. Referring to Figure 
F, the tree is traversed to count the number of nodes at 
each level in the hierarchy, step 901 . Each level will form 
a column so a node count for each column is created. In 
a preferred embodiment, each nodes when displayed is 
80 X 20 pixels in size. Thus, the size of a column can be 
readily determined. This will correspond to the number 
of nodes in a column. Next, a bounding rectangle for 
each column is determined, step 902. The bounding rec- 
tangle is based on the number of columns, the number 
of nodes in each column, and the dimensions of the dis- 
play window. The bounding rectangle will encompass all 
the nodes in a level of the hierarchy. The tree is then 
traversed to place the nodes in the plane in terms of 
plane coordinates, step 903. For the placement, the x 
coordinate is determined by the nodes depth in the hier- 
archy and the number of levels in the hierarchy. The y 
coordinate is determined by the node's position within 
the column as the tree structure is traversed. 

Referring back to Figure 7, the tree layout is then 
rendered on the reference surface, step 701. This is ac- 
complished by transforming the plane coordinates to dis- 
play screen coordinates. The transformation that takes 
place depends on the panel. As described above, the 
reference surface relates to the plane in that it merely 
folds at predetermined vertical fold locations (i.e. at a 
particular Y-ccordinate in the plane). So determination 
of which transformation to use requires examination of 
the Y-coordinate of the node. For the center panel, plane 
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coordinates are scaled to the those of the reference sur- 
face. For the top and bottom panels look-up tables are 
used to apply perspective transformations on the plane 
coordinates. For each of the top and bottom panels two 
look-up tables are used. One look-up table maps plane s 
y-distance from a panel fold to screen y-distance. A sec- 
ond look-up table maps plane x-distance from the center 
to screen x-distance from the center. 

As described above with respect to Figure 6, when 
a leaf node is in the top or bottom panel and the path to '0 
that leaf node is selected, scrolling of the tree may occur. 
Figure 10 is a flowchart describing the steps for scrolling. 
The scrolling of a preferred embodiment is intended to 
provide animation. It has been determined that anima- 
tion aids the users perception of what is occurring. To »s 
accommodate animation, the scrolling occurs in anima- 
tion steps with a total animation time of 0.6 seconds 
(which has been determined to be optimal). Referring to 
Figure 10, First the distance each column of the tree will 
need to travel is determined, step 1001. In a preferred 20 
embodiment the selected nodes, its ancestors and its 
children will be centered on the reference surface. The 
distance that must be traveled in each animation step so 
that the most distant column will get to its destination is 
then determined, step 1002. This distance is based on 25 
the time required for recent tree renderings. This dis- 
tance will provide an offset for each column for each an- 
imation step. The animations steps are then performed, 
step 1003. Here, tree is rendered on the reference sur- 
face incrementing each column's offset towards its des- 30 
tination at each step until all of the columns are at their 
final destinations. 

Internal Representation of a Node 

35 

Figure 11 illustrates a data structure for a node in a 
tree structure in the currently preferred embodiment of 
the present invention. The structure is comprised of a 
plurality of pointers 1101 -1 1 04 and a layout address for 
the node, 1 1 05. The pointer 1101 points to a parent node, 40 
the pointer 1 1 02 points to a child node, the pointer 1 1 03 
points to a sibling node and the pointer 1104 points to 
document information. The pointers 1101-1103 are typ- 
ical for a tree structure representation. The pointer 1104 
is used to point to the document itself. The layout ad- *s 
dress 1105 contains the address for the node with re- 
spect to the plane as generated in the layout plane step 
described in Figure 9. 

Screen Displays of the Currently Preferred so 
Embodiment. 

Figures 12-14 "Copyright 1 994, Xerox Corporation" 
(17U.S.C. 401) are screen displays illustrating the infor- 
mation visualization of database search. Referring to ss 
Figure 12, a tree of a search result is illustrated. Here we 
see that various nodes have been rendered on the top 
and bottom panels. Figure 13 illustrates the highlighting 



of a node along with its descendant nodes. Referring to 
Figure 13, the node 1301 is selected and highlighted. 
This results in the descendant nodes 1 302-1 305 to also 
be highlighted. Finally, Figure 14 illustrates a selection 
which causes scrolling. Assuming the starting position 
as illustrated in Figure 12, node 1401 is selected. The 
descendant nodes 1402-1411 are then scrolled to the 
center panel and highlighted. Note that nodes have 
scrolled off the center panel and onto the bottom panel. 

Claims 

1 . A method for generating hierarchically related infor- 
mation for the results of a query to a database, said 
database for storing documents, said method com- 
prising the steps of: 

a) executing a search on a database to obtain 
a set of documents; 

b) receiving a set of N ordered user specified 
view preferences, each of said user specified 
view preferences defining a property of informa- 
tion stored in said database; 

c) generating an N + 1 level tree structure based 
on said set of documents and said set of N 
ordered user specified view preferences; 

d) displaying a reference surface on which said 
tree structure is displayed, said reference sur- 
face having a first area for showing a first portion 
of the tree structure in detail and a second area 
for showing second portions of said tree struc- 
ture lacking detail; 

e) determining a layout of said tree structure rel- 
ative to said reference surface; 

f) mapping said tree structure to said reference 
surface based on said layout to create tree dis- 
play data; and 

g) displaying said tree structure on said refer- 
ence surface. 

2. The method as recited in C laim 1 wherein each node 
in said N + 1 level of said tree structure points to a 
corresponding document and each of said N levels 
corresponds to one of said N ordered user specified 
view preferences. 

3. The method as recited in Claim 2 wherein said step 
of generating an N + 1 level tree structure is further 
comprised of: 

for each document at each of said 1 to N levels per- 
forming the steps of: 
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c1 ) retrieving a value for said document at a 
level being processed; 

c2) determining if a child node exists having said 
value; s 

c3) if no child nodes exists, creating a new child 
node having said value and processing next 
level; and 

w 

c4) if a child exists having said value, process- 
ing next level. 

4. The method as recited in Claim 1 wherein N is less 
than or equal to 5. is 



A computer controlled display system for displaying 
the results of queries to a database comprising: 

receiving means for receiving a set of docu- 
ment indicators, said set of document indicators cor- 20 
responding to the results of a database query; 

means for specifying one or more search pref- 
erences; 

means for constructing a tree structure based 
on said one or more search preferences and said 25 
set of document indicators; 

means for generating a reference surface on 
which said tree structure is displayed, said reference 
surface having a first area for showing a first portion 
of the tree structure in detail and a second area for 30 
showing second portions of said tree structure lack- 
ing detail; 

layout generation means for generating a lay- 
out of said tree structure relative to said reference 
surface; 35 

mapping said tree structure to said reference 
surface based on said layout to create tree display 
data; and 

display means for displaying said tree struc- 
ture on said reference surface. 40 



6. The system as recited in Claim 5 further comprising 
of means for causing said tree structure to be 
scrolled across said reference surface. 

7. The system as recited in Claim 5 or 6 further com- 
prising means for highlighting a document path in 
said tree structure. 



8. The system as recited in Claims 5, 6 or 7 further so 
comprising means for enabling viewing a document 
from said tree structure. 



9. The system as recited in any of Claims 5 to 8 further 
comprising means for enabling retrieval of a docu- ss 
ment for editing from said tree structure. 
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